home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Apple WWDC 1996
/
WWDC96_1996 (CD).toast
/
Technology Materials
/
MacOS 8 Resources
/
Developer Tools
/
Mac OS 8 Interfaces & Libraries
/
Interfaces
/
PInterfaces
/
fenv.p
< prev
next >
Wrap
Text File
|
1996-05-01
|
10KB
|
275 lines
{
File: fenv.p
Copyright: © 1984-1994 by Apple Computer, Inc.
All rights reserved.
Version: Universal Pascal, July 8, 1994
Note: The following file was hand converted from fenv.h
See fenv.h for more information and comments.
}
{$IFC UNDEFINED UsingIncludes}
{$SETC UsingIncludes := 0}
{$ENDC}
{$IFC NOT UsingIncludes}
UNIT fenv;
INTERFACE
{$ENDC}
{$IFC UNDEFINED __FENV__}
{$SETC __FENV__ := 1}
{$I+}
{$SETC fpenvIncludes := UsingIncludes}
{$SETC UsingIncludes := 1}
{$IFC UNDEFINED __TYPES__}
{$I Types.p}
{$ENDC}
{$IFC GENERATINGPOWERPC }
TYPE
{ fenv_t is a type for representing the entire floating-point
environment in a single object. }
fenv_t = LONGINT;
{ fexcept_t is a type for representing the floating-point
exception flag state collectively. }
fexcept_t = LONGINT;
CONST
{ Definitions of floating-point exception macros }
FE_INEXACT = $02000000; { inexact }
FE_DIVBYZERO = $04000000; { divide-by-zero }
FE_UNDERFLOW = $08000000; { underflow }
FE_OVERFLOW = $10000000; { overflow }
FE_INVALID = $20000000; { invlalid }
{ Definitions of rounding direction macros }
FE_TONEAREST = $00000000;
FE_TOWARDZERO = $00000001;
FE_UPWARD = $00000002;
FE_DOWNWARD = $00000003;
{$ELSEC}
CONST
FE_TONEAREST = $0000;
FE_UPWARD = $0001;
FE_DOWNWARD = $0002;
FE_TOWARDZERO = $0003;
{ Definitions of rounding precision macros (68K only) }
FE_LDBLPREC = $0000;
FE_DBLPREC = $0001;
FE_FLTPREC = $0002;
{$IFC OPTION(mc68881) }
TYPE
fenv_t = RECORD
FPCR: LONGINT;
FPSR: LONGINT;
END;
fexcept_t = LONGINT;
CONST
FE_INEXACT = $00000008;
FE_DIVBYZERO = $00000010;
FE_UNDERFLOW = $00000020;
FE_OVERFLOW = $00000040;
FE_INVALID = $00000080;
{$ELSEC}
TYPE
fenv_t = INTEGER;
fexcept_t = INTEGER;
CONST
FE_INVALID = $0001;
FE_UNDERFLOW = $0002;
FE_OVERFLOW = $0004;
FE_DIVBYZERO = $0008;
FE_INEXACT = $0010;
{$ENDC}
{$ENDC}
{ The bitwise OR of all exception macros }
FE_ALL_EXCEPT = FE_INEXACT + FE_DIVBYZERO + FE_UNDERFLOW + FE_OVERFLOW + FE_INVALID;
{ Definition of pointer to IEEE default environment object }
VAR
{$PUSH}
{$J+}
_FE_DFL_ENV: fenv_t; {default environment object }
{$POP}
(******************************************************************************
* The following functions provide access to the exception flags. The *
* "int" input argument can be constructed by bitwise ORs of the exception *
* macros: for example: FE_OVERFLOW | FE_INEXACT. *
*******************************************************************************)
(*******************************************************************************
* The function "feclearexcept" clears the supported exceptions represented *
* by its argument. *
*******************************************************************************)
PROCEDURE feclearexcept( excepts: LONGINT ); C;
(*******************************************************************************
* The function "fegetexcept" stores a representation of the exception *
* flags indicated by the argument "excepts" through the pointer argument *
* "flagp". *
*******************************************************************************)
PROCEDURE fegetexcept( VAR flagp: fexcept_t;
excepts: LONGINT ); C;
(*******************************************************************************
* The function "feraiseexcept" raises the supported exceptions *
* represented by its argument. *
*******************************************************************************)
PROCEDURE feraiseexcept( excepts: LONGINT ); C;
(*******************************************************************************
* The function "fesetexcept" sets or clears the exception flags indicated *
* by the int argument "excepts" according to the representation in the *
* object pointed to by the pointer argument "flagp". The value of *
* "*flagp" must have been set by a previous call to "fegetexcept". *
* This function does not raise exceptions; it just sets the state of *
* the flags. *
*******************************************************************************)
PROCEDURE fesetexcept( VAR flagp: fexcept_t; excepts: LONGINT ); C;
(*******************************************************************************
* The function "fetestexcept" determines which of the specified subset of *
* the exception flags are currently set. The argument "excepts" specifies *
* the exception flags to be queried as a bitwise OR of the exception *
* macros. This function returns the bitwise OR of the exception macros *
* corresponding to the currently set exceptions included in "excepts". *
*******************************************************************************)
FUNCTION fetestexcept( excepts: LONGINT ): LONGINT; C;
(*******************************************************************************
* The following functions provide control of rounding direction modes. *
*******************************************************************************)
(*******************************************************************************
* The function "fegetround" returns the value of the rounding direction *
* macro which represents the current rounding direction. *
*******************************************************************************)
FUNCTION fegetround: LONGINT; C;
(*******************************************************************************
* The function "fesetround" establishes the rounding direction represented *
* by its argument. It returns nonzero if and only if the argument matches *
* a rounding direction macro. If not, the rounding direction is not *
* changed. *
*******************************************************************************)
FUNCTION fesetround(round: LONGINT): LONGINT; C;
(*******************************************************************************
* The following functions manage the floating-point environment, exception *
* flags and dynamic modes, as one entity. *
*******************************************************************************)
(*******************************************************************************
* The function "fegetenv" stores the current floating-point environment *
* in the object pointed to by its pointer argument "envp". *
*******************************************************************************)
PROCEDURE fegetenv( VAR envp: fenv_t ); C;
(*******************************************************************************
* The function "feholdexcept" saves the current environment in the object *
* pointed to by its pointer argument "envp", clears the exception flags, *
* and clears floating-point exception enables. This function supersedes *
* the SANE function "procentry", but it does not change the current *
* rounding direction mode. *
*******************************************************************************)
FUNCTION feholdexcept( VAR envp: fenv_t ): LONGINT; C;
(*******************************************************************************
* The function "fesetenv" installs the floating-point environment *
* environment represented by the object pointed to by its argument *
* "envp". The value of "*envp" must be set by a call to "fegetenv" or *
* "feholdexcept", by an implementation-defined macro of type "fenv_t", *
* or by the use of the pointer macro FE_DFL_ENV as the argument. *
*******************************************************************************)
PROCEDURE fesetenv( VAR envp: fenv_t ); C;
(*******************************************************************************
* The function "feupdateenv" saves the current exceptions into its *
* automatic storage, installs the environment represented through its *
* pointer argument "envp", and then re-raises the saved exceptions. *
* This function, which supersedes the SANE function "procexit", can be *
* used in conjunction with "feholdexcept" to write routines which hide *
* spurious exceptions from their callers. *
*******************************************************************************)
PROCEDURE feupdateenv( VAR envp: fenv_t ); C;
{$IFC GENERATING68K}
(*******************************************************************************
* The following functions provide control of rounding precision. *
* Because the PowerPC does not provide this capability, these functions *
* are available only for the 68K Macintosh. Rounding precision values *
* are defined by the rounding precision macros. These functions are *
* equivalent to the SANE functions getprecision and setprecision. *
*******************************************************************************)
FUNCTION fegetprec: LONGINT; C;
FUNCTION fesetprec (precision: LONGINT): LONGINT; C;
{$ENDC}
{$SETC UsingIncludes := fpenvIncludes}
{$ENDC} {__FPENV__}
{$IFC NOT UsingIncludes}
END.
{$ENDC}